const Client = require("ali-mysql-client");

const config = {
  host: process.env.MYSQL_HOST, // 数据库主机地址
  port: process.env.MYSQL_PORT, // 数据库主机端口
  user: process.env.MYSQL_USER, // 数据库用户名
  password: process.env.MYSQL_PASSWORD, // 数据库密码
  database: process.env.MYSQL_DATABASE, // 数据库名
  timezone: "SYSTEM",
  connectionLimit: 10, // 最大连接数
  waitForConnections: true, // 如果连接池已满，是否等待连接
  queueLimit: 0, // 连接请求队列的最大长度，0表示无限制
};

const pool = new Client(config);

const customizeConfig = pool.config();

// 自定义operator
customizeConfig.registerOperator("ne", ({ field, value }) => {
  return { sql: "?? <> ?", arg: [field, value] };
});

// 自定义ignore
customizeConfig.registerIgnore("ifNumber", ({ value }) => {
  return !isNaN(Number(value));
});

// 监听事件 执行前
customizeConfig.onBeforeExecute(function ({ sql }) {
  console.log(sql);
});

// 监听事件 执行后
customizeConfig.onAfterExecute(function ({ sql, result }) {
  // console.log(result);
});

// 监听事件 执行出错
customizeConfig.onExecuteError(function ({ sql, error }) {
  console.log(error);
});

module.exports = pool;
